#include <iostream>

void insertionSort(int arr[], int n) {
    for (int i = 1; i < n; ++i) {
        int key = arr[i];
        int j = i - 1;
        
        // 将arr[i]与已排序的arr[0...i-1]中的元素进行比较，找到插入位置
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];  // 向后移动元素
            j = j - 1;
        }
        arr[j + 1] = key;  // 插入key
    }
}

